package cn.com.leetcode.divideandconquer;

/**
 * 给定一个大小为 n 的数组，找到其中的多数元素。多数元素是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素。
 * <p>
 * 你可以假设数组是非空的，并且给定的数组总是存在多数元素。
 * <p>
 *  
 * <p>
 * 示例 1:
 * <p>
 * 输入: [3,2,3]
 * 输出: 3
 * 示例 2:
 * <p>
 * 输入: [2,2,1,1,1,2,2]
 * 输出: 2
 * <p>
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/majority-element
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
public class Demo169 {
    public static void main(String[] args) {
        Demo169 demo169 = new Demo169();
        int[] nums = {2, 2, 1, 1, 1, 2, 2};
        int mode = demo169.majorityElement(nums);
        System.out.println(mode);

    }

    public int majorityElement(int[] nums) {
        int mode = 0;
        int count = 0;
        for (int num : nums) {
            if (count == 0) {
                mode = num;
            }
            if (mode == num) {
                count++;
            } else {
                count--;
            }
        }
        return mode;
    }
}
